package org.jypj.dev.service;

import org.jypj.dev.model.TrainNumInfo;
import org.jypj.dev.util.Page;

import java.util.List;
import java.util.Map;

public interface TrainNumInfoService {


    /**
     * 保存
     * 所有字段全都保存
     *
     * @param trainNumInfo
     * @return
     */
    int saveTrainNumInfo(TrainNumInfo trainNumInfo);

    /**
     * 保存
     * 所有字段全都保存
     *
     * @return
     */
    int saveOrUpdateTrainNumInfos(List<TrainNumInfo> trainNumInfos);

    /**
     * 根据ID删除
     *
     * @param id 主键ID
     * @return 删除记录数
     */
    int deleteTrainNumInfoById(String id);

    /**
     * 根据对象删除
     *
     * @param trainNumInfo
     * @return
     */
    int deleteTrainNumInfoByObject(TrainNumInfo trainNumInfo);

    /**
     * 更新
     * 更新所有字段
     *
     * @param trainNumInfo
     * @return
     */
    int updateTrainNumInfo(TrainNumInfo trainNumInfo);

    /**
     * 按ID查询
     *
     * @return TrainNumInfo
     * @parm id 主键ID
     */
    TrainNumInfo selectTrainNumInfoById(String id);

    /**
     * 分页查询 包含条件
     *
     * @param page 分页对象
     * @param map  查询条件
     * @return List<TrainNumInfo>
     */
    Page selectOnePageByMap(Page page, Map<String, Object> map);

    /**
     * 分页查询 包含对象条件
     *
     * @param page 分页对象
     * @param map  查询条件
     * @return Page
     */
    Page selectOnePageByTrainNumInfo(Page page, TrainNumInfo trainNumInfo);

    /**
     * 按条件查询全部的
     *
     * @param map 查询条件
     * @return List<TrainNumInfo>
     */
    List<TrainNumInfo> selectAllByMap(Map<String, Object> map);


    /**
     * 按条件查询全部的
     *
     * @param trainNumInfo 查询条件
     * @return List<TrainNumInfo>
     */
    List<TrainNumInfo> selectAllByTrainNumInfo(TrainNumInfo trainNumInfo);

    /**
     * 按条件查询单个对象
     *
     * @param map 查询条件
     * @return TrainNumInfo
     */
    TrainNumInfo selectObjectByMap(Map<String, Object> map);

    /**
     * 按条件查询单个对象
     *
     * @param trainNumInfo 查询条件
     * @return TrainNumInfo
     */
    TrainNumInfo selectObjectByTrainNumInfo(TrainNumInfo trainNumInfo);

}
